清理原有的mysql数据库
使用以下命令查找出安装的mysql软件包和依赖包:
rpm -pa | grep mysql |
可能显示结果如下:
mysql80-community-release-el7-1.noarch |
使用以下命令依次删除上面的程序
yum remove mysql-xxx-xxx- |
删除mysql的配置文件,卸载不会自动删除配置文件,此命令很慢;
find / -name mysql |
可能的显示结果如下:
/etc/logrotate.d/mysql |
根据需求使用以下命令 依次 对配置文件进行删除
rm -rf /var/lib/mysql |
安装mysql
centos的yum 源中默认是没有mysql的,所以我们需要先去官网下载mysql的repo源并安装;
mysql官网下载链接:mysql repo下载地址
然后将文件上传到服务器
安装 yum repo文件并更新 yum 缓存;
rpm -ivh mysql-XXX-XXX.rpm |
安装mysql 命令如下:
yum install mysql-community-server |
开启mysql 服务
systemctl start mysqld.service |
查看原始初始化密码
sudo grep 'temporary password' /var/log/mysqld.log |
登陆本地mysql
mysql -u root -p |
然后输入刚才得到的初始密码登陆:
以下是我的踩坑点,没有遇到的就跳过
踩坑1:报错信息:Access denied for user ‘root’@’localhost’ (using password: YES)
解决办法:
找到my.cnf文件:位置在/etc/my.cnf,打开文件在最后加上 skip-grant-tables
此时我的配置文件内容是:[mysqld]
port=3306
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
skip-grant-tables
然后重启mysql服务再登陆mysql(输入密码时直接回车)
第一次进来记得先修改密码:
flush privileges; |
use mysql; |
查看当前root用户相关信息,在mysql数据库的user表中;
select host, user, authentication_string, plugin from user; |
host: 允许用户登录的ip‘位置’%表示可以远程;
user:当前数据库的用户名;
authentication_string: 用户密码;在mysql 5.7.9以后废弃了password字段和password()函数;
plugin: 密码加密方式;
先将authentication_string设置为空update user set authentication_string='' where user='root';
使用ALTER修改root用户密码;
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY'新密码'; |
踩坑2:报错信息Table ‘mysql.role_edges’ doesn’t exist
说我的表不存在,然后我想去查询当前有哪些表结果又报错:The user specified as a definer (‘mysql.infoschema’@’localhost’) does not ex
其实主要是因为在my.cnf配置文件中skip_name*跳过了域名解析并且删除掉了user表中所有localhost为地址的用户
解决办法:
mysql> SET GLOBAL innodb_fast_shutdown = 1;
重启mysqlservice mysqld restart
然后用下面的命令、密码直接回车:mysql_upgrade -u root -p
用升级的方式将这些用户重新添加了回来,成功后效果类似这样
然后再次重启mysql
再按照上面的步奏修改密码
然后将之前加的skip-grant-tables去掉,再重启就可以登陆了
远程登陆授权:
查看用户信息
select host, user, authentication_string, plugin from user; |
用sql语句将你需要远程登陆的用户的host改为%,这样就可以让所有地址可以登陆了